<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta http-equiv="X-UA-Compatible" content="IE=edge" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>案例-头像上传</title>
    <link rel="stylesheet" href="./lib/bootstrap-v4.6.0.css" />
    <style>
      .thumb-box {
        text-align: center;
        margin-top: 50px;
      }

      .thumb {
        width: 150px;
        height: 150px;
        object-fit: cover;
        border-radius: 50%;
      }
    </style>
  </head>

  <body>
    <div class="thumb-box">
      <!-- 头像 -->
      <img src="./images/cover.jpg" class="img-thumbnail thumb" alt="" />
      <div class="mt-2">
        <!-- 文件选择框 -->
        <!-- accept 属性表示可选择的文件类型 -->
        <!-- image/* 表示只允许选择图片类型的文件 -->
        <input
          type="file"
          id="iptFile"
          accept="image/*"
          style="display: none"
        />
        <!-- 选择头像图片的按钮 -->
        <button class="btn btn-primary" id="btnChoose">选择 & 上传图片</button>
      </div>
    </div>
    <script src="./lib/axios.js"></script>
    <script>
      // 点击按钮时 触发 input的点击事件
      document.querySelector('#btnChoose').onclick = function () {
        // 用js代码 模拟了点击
        document.querySelector('#iptFile').click()
      }
      // input标签的change事件
      document.querySelector('#iptFile').onchange = function (e) {
        // console.log('e:', e)
        console.log('e.target.files:', e.target.files)
        // 获取图片
        const img = e.target.files[0]
        // 组成 FormData并提交
        const data = new FormData()
        data.append('avatar', img)
        // console.log(data.get('avatar'))
        // console.log(img.type.indexOf('image')!==-1)
        if (img.type.indexOf('image') !== -1) {
          axios({
            url: 'http://ajax-api.itheima.net/api/file',
            method: 'post',
            data, // data:data
          }).then((res) => {
            console.log('res:', res)
            // 把地址设置给img的src属性
            document.querySelector('.img-thumbnail').src = res.data.data.url
          })
        } else alert('请上传一张图片')
      }
    </script>
  </body>
</html>
